{% extends "base.html" %}

{% set active_page = "Home" %}

{% block head %}
 
{% endblock %}

{% block styles %}
<link rel="stylesheet" type="text/css" href="{{ url_for('static', filename='css/home.css') }}">

{% endblock %}

{% block body %}
    <div class="row justify-content-center mt-4">

        <div class="p-0 m-2">
            <center>
                <img width="100%" height="auto" src="{{ url_for('static', filename='fact_logo.png') }}" style="max-width: 445px;">

                <br /><br />

                <h4 class="mb-3">General FACTs</h4>
                <table class="table table-sm table-responsive" style="width: 705px;">
                    <tbody>
                        <tr>
                            <td style="text-align: left; padding:5px">firmware samples</td>
                            <td style="text-align: right; padding:5px">{{ general_stats['number_of_firmwares'] | nice_number }}</td>
                        </tr>
                        <tr>
                            <td style="text-align: left; padding:5px">firmware total size</td>
                            <td style="text-align: right; padding:5px">{{ general_stats['total_firmware_size'] | number_format }}</td>
                        </tr>
                        <tr>
                            <td style="text-align: left; padding:5px">firmware average size</td>
                            <td style="text-align: right; padding:5px">{{ general_stats['average_firmware_size'] | number_format }}</td>
                        </tr>
                        <tr>
                            <td style="text-align: left; padding:5px">unique included files</td>
                            <td style="text-align: right; padding:5px">{{ general_stats['number_of_unique_files'] | nice_number }}</td>
                        </tr>
                        <tr>
                            <td style="text-align: left; padding:5px">unique included files total size</td>
                            <td style="text-align: right; padding:5px">{{ general_stats['total_file_size'] | number_format }}</td>
                        </tr>
                        <tr>
                            <td style="text-align: left; padding:5px">unique included files average size</td>
                            <td style="text-align: right; padding:5px">{{ general_stats['average_file_size'] | number_format }}</td>
                        </tr>
                        <tr>
                            <td style="text-align: left; padding:5px">statistic generation time</td>
                            <td style="text-align: right; padding:5px">{{ general_stats['benchmark'] | nice_number }} s</td>
                        </tr>
                        <tr>
                            <td style="text-align: left; padding:5px">backend cpu load</td>
                            <td id="cpu_percentage" style="text-align: right; padding:5px">n/a</td>
                        </tr>
                        <tr>
                            <td style="text-align: left; padding:5px">currently analyzed firmware</td>
                            <td id="currently_running" style="text-align: right; padding:5px">n/a</td>
                        </tr>
                    </tbody>
                </table>
            </center>
        </div>
        <script>
            function load_ajax_stats(){
                let system_data = $.getJSON("/ajax/stats/system")
                .done(function(system_data) {
                    document.getElementById("cpu_percentage").innerHTML = system_data.backend_cpu_percentage;

                    let running_node =  document.getElementById("currently_running");
                    if (system_data.number_of_running_analyses > 0) {

                        if (! running_node.classList.contains('text-success')) {
                            running_node.classList.add('text-success');
                        }
                    } else {
                        if (running_node.classList.contains('text-success')) {
                            running_node.classList.remove('text-success');
                            }
                    }

                    running_node.innerHTML = system_data.number_of_running_analyses;
                });
            }

            load_ajax_stats();
            setInterval(function(){
                load_ajax_stats()
            }, {{ ajax_stats_reload_time }});
        </script>

        {% if (latest_firmware_submissions | length) > 0 %}
            <div class="card p-2 m-2 bg-light rounded border-0" style="width: 705px;">
                <div class="card-body bg-light p-3">
                    <h4 class="card-title mb-3">Latest Firmware Submissions</h4>
                    <ul class="list-group-flush px-0 mb-0">
                        {% for firmware in latest_firmware_submissions %}
                            {{ firmware | firmware_detail_tabular_field | safe }}
                        {% endfor %}
                    </ul>
                </div>
            </div>
        {% endif %}

    </div>

    {# Latest Comments #}
    <div class="row justify-content-center">
        {% if (latest_comments | length) > 0 %}
            <div class="card p-2 m-2 bg-light rounded border-0" style="width: 705px;">
                <div class="card-body p-3">
                    <h4 class="card-title mb-3">Latest Comments</h4>
                    <ul class="list-group-flush px-0">
                        {% for comment in latest_comments %}
                            <li class="list-group-item bg-light p-2 clickable li-hover" onclick="location.href='/analysis/{{ comment.uid }}'">
                                <a href="/analysis/{{ comment.uid }}" style="color: #515151;">
                                    <div class="p-1" style="width: 100%; height: 100%; font-size: 14px;">
                                        <div class="bubble bubble-triangle mb-2">
                                            {{ comment.comment }}
                                        </div>
                                        <div class="footnote">
                                            <span style="color: #000;">{{ comment.author }}</span> ‒ <span class="text-muted">{{ comment.time | int | nice_unix_time }}</span>
                                        </div>
                                    </div>
                                </a>
                            </li>
                        {% endfor %}
                    </ul>
                </div>
            </div>
        {% endif %}

        {# latest_comparison_results #}
        {% if (latest_comparison_results | length) > 0 %}
            <div class="card p-2 m-2 bg-light rounded border-0" style="width: 705px;">
                <div class="card-body p-3">
                    <h4 class="card-title mb-3">Latest Comparisons</h4>
                    <ul class="list-group list-group-flush px-0">
                        {% for id, hids, submission_date in latest_comparison_results %}
                            <li class="list-group-item bg-light p-2 clickable li-hover" onclick="location.href='/compare/{{ id }}'">
                                <a href="/compare/{{ id }}" style="color: #515151;">
                                    <div class="p-1" style="width: 100%; height: 100%; font-size: 14px;">
                                        {% for uid in hids %}
                                            {{ hids[uid] }}
                                            <div class="footnote">{{ uid }}</div>
                                        {% endfor %}
                                        <span class="footnote text-muted">
                                            {{ submission_date | int | nice_unix_time }}
                                        </span>
                                    </div>
                                </a>
                            </li>
                        {% endfor %}
                    </ul>
                </div>
            </div>
        {% endif %}
    </div>

{% endblock %}
